//给你一个整数数组 nums。 
//
// 返回两个（不一定不同的）质数在 nums 中 下标 的 最大距离。 
//
// 
//
// 示例 1： 
//
// 
// 输入： nums = [4,2,9,5,3] 
// 
//
// 输出： 3 
//
// 解释： nums[1]、nums[3] 和 nums[4] 是质数。因此答案是 |4 - 1| = 3。 
//
// 示例 2： 
//
// 
// 输入： nums = [4,8,2,8] 
// 
//
// 输出： 0 
//
// 解释： nums[2] 是质数。因为只有一个质数，所以答案是 |2 - 2| = 0。 
//
// 
//
// 提示： 
//
// 
// 1 <= nums.length <= 3 * 10⁵ 
// 1 <= nums[i] <= 100 
// 输入保证 nums 中至少有一个质数。 
// 
//
// Related Topics 数组 数学 数论 👍 3 👎 0


package leetcode.editor.cn;

import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;

class MaximumPrimeDifference{
    public static void main(String[] args) {
        Solution solution = new Solution();
    }
    static
    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public int maximumPrimeDifference(int[] nums) {
            Set<Integer> primes = new HashSet<>(Arrays.asList(2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97));
            int maxIdx = Integer.MIN_VALUE;
            int minIdx = Integer.MAX_VALUE;
            for (int i = 0; i < nums.length; i++) {
                if(!primes.contains(nums[i])) continue;
                maxIdx = Math.max(maxIdx, i);
                minIdx = Math.min(minIdx, i);
            }
            return maxIdx - minIdx;
        }
    }
    //leetcode submit region end(Prohibit modification and deletion)

}